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(54) Method for on-demand network application download and execution 



(57) Methods for executing an applet (310) is dis- 
closed. A virtual machine (312) that includes a class 
loader (314) generates a file download request in the 
form of an http request to a particular server computer 
(304) that contains appropriate applet component files. 
The class loader (314) queries a root JAR file having an 
index file (316) associated with applet. The class loader 



(314) creates a HASH table (318) based upon the con- 
tents of the index file (316) that provides a mapping of 
all packages and all corresponding JAR files required to 
execute the applet (310) by the virtual machine (312). 
During virtual machine runtime the class loader (314) 
queries the HASH table (31 8) in order to directly access 
the appropriate applet component file to be downloaded 
and executed by the virtual machine (312). 
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D scription 

BACKGROUND OF THE INVENTION 
1. Field of Invention 



[0001] The invention relates generally to computer 
systems. More particularly, methods and apparatus for 
providing on-demand network application download 
and execution capabilities in a distributed computer net- 
work are disclosed. 



2. Description of Relevant Art 

[0002] Generally speaking, a browser is an applica- 
tion program that provides a way to look at and interact 
with all the information on the distributed computer net- 
works such as the Internet. In particular, a Web browser 
is a client program that uses the Hypertext Transfer Pro- 
tocol (HTTP) to make requests of Web servers through- 
out the Internet on behalf of the browser user. Java™ 
a programming language developed by Sun Microsys- 
tems Inc. of Mountain View CA, is expressly designed 
for use in the distributed environment of the Internet It 
was designed to have the "look and feel" of the C++ lan- 
guage, but it is simpler to use than C++ and enforces a 
completely object-oriented view of programming. In this 
way, Java is used to create complete applications that 
can run on a single computer or be distributed among 
servers and clients in a network. 
[0003] One of the many advantages of Java is that it 
can also be used to build small application modules or 
applets, for use as part of a Web page. A Java applet is 
a small program that can be sent along with a Web page 
to a user that can perform interactive animations, imme- 
diate calculations, or other simple tasks without having 
to send a user request back to the server. As an exam- 
ple, as shown in Fig. 1, a distributed computer system 
100 includes a client computer 102 that is coupled to a 
server (host) computer 1 04. The computer 1 02 includes 
a browser application 106 that, in turn, includes a re- 
quested Web page 108 having an applet 110embedded 
therein capable of performing various tasks. In most sit- 
uations, the applet 1 1 0 is executed by a Java Virtual Ma- 
chine (JVM) 112 that in this example is also resident in 
the browser 106. 

[0004] In order for the JVM 112 to execute the applet 
110, the applet's requisite component files (such as ". 
class files", images and sounds) represented by files 
114-118 must be downloaded from the server 1 04 to the 
JVM 1 1 2. Typically the server 1 04 is part of a distributed 
network of computers, such as the Internet, or in some 
cases could be part of an intranet type of arrangement 
In any case, the files 114-118 that are required for the 
JVM 112 to run the applet 110 include Java class files 
as well as resource files that are used to support the 
execution of the applet 110. Such class files, includes a 
mam class file, main.class 114, that is used by the JVM 
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112 as an entry point for execution of the applet 110 
The server104 also stores other class files such as b 
class 116 that are used by the JVM 112 in the further- 
ance of executing the applet 110. Various image and 
5 sound components used in the execution of the applet 
110 are stored in resource files such as c.image 118 
[0005] In order for the JVM 112 to execute the applet 
110, it may be required to download some of the class 
and resource files as needed. This is typically accom- 
™ plished by sending a file request that takes the form of 
an http request to the server 1 04 which responds by pro- 
viding an http response that includes the URL of the re- 
quested file. By way of example, the JVM 112 issues a 
request to retrieve the main class file main.class 114 to 
« which the server 104 responds by sending (i.e , down- 
loading) the requested file (i.e., main.class 114) This 
request/response procedure is followed for every file for 
which the JVM 112 requires to execute the applet 110. 
[0006] This arrangement, though inefficient, is satis- 
factory for executing most small applets on small local 
networks. However as the complexity of the applet in- 
creases (thereby increasing both the size and the 
number of requested files), the performance of the JVM 
112 is substantially degraded since the time required to 
25 satisfy the increasingly voluminous requests for the in- 
creasingly larger files in an increasingly more complex 
network of computers becomes excessive. 
[0007] With the introduction of what is referred to as 
a Java Archive (JAR) file, the performance of network 
30 Java applications, such as applets, is somewhat im- 
proved. A JAR (Java Archive) file has a platform-inde- 
pendent file format that aggregates many files into one 
In those applications using JAR files, multiple Java ap- 
plets and their requisite components (.class files imag- 
es es and sounds, etc.) can be bundled in a JAR file and 
subsequently downloaded to a browser in a single HTTP 
transaction thereby greatly improving the download 
speed. In addition, the JAR format also supports com- 
pression, which reduces the file size, further improving 
40 the download time. For example, referring to Fig 2 the 
applet component files 114 - 118 are stored in a single 
JAR file 120. Using this arrangement, in order for the 
JVM 1 1 2 to execute the applet 1 1 0, only a single HTTP 
file request 1 22 is required to download the compressed 
JAR file 120 that contains all the applet component files 
114-118. 

[0008] When an applet includes multiple JAR files a 
class loader will construct an internal search path of JAR 
files and whenever it tries to load a class or resource 
so file, it would linearly search each JAR file on its search 
■ path in the process downloading and opening each of 
them. If the class loader tries to find a resource file that 
does not exist at all, then all the JAR files will be down- 
loaded, even if most of them are not needed for the ap- 
55 plet to run. K 
[0009] Therefore, what is desired is a method for pro- 
viding efficient on-demand downloading of files in a dis- 
tributed network environment. 
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SUMMARY OF THE INVENTION 

[0010] In one embodiment of the present invention, a 
method for executing an applet is disclosed. A file down- 
load request for a root file is provided to a particular serv- 
er computer by a virtual machine that is used to execute 
the applet. The requested root file includes applet com- 
ponent files used by the virtual machine to execute the 
applet such that related ones of the component files are 
grouped into a corresponding package. The root file in- 
cludes an index file that contains information that relates 
the mapping of the package to corresponding related 
applet component files. A HASH table based upon the 
contents of the index file is then created that provides a 
mapping of all packages and all corresponding compo- 
nent files that are used by the virtual machine to execute 
the applet. During virtual machine runtime, the HASH 
table is queried for a location of a particular applet com- 
ponent file after which the particular applet component 
file is directly downloaded to the virtual machine. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0011] The invention, together with further advantag- 
es thereof, may best be understood by reference to the 
following description taken in conjunction with the ac- 
companying drawings in which: 

Fig. 1 shows a conventional distributed computer 
system capable of supporting a Java based brows- 
er/server configuration; 

Fig. 2 shows the distributed computer system of Fig. 
1 where the various applet components are stored 
in a single JAR file. 

Fig. 3 shows a distributed computer system ar- 
ranged to support a Java based browser/server ar- 
rangement in accordance with an embodiment of 
the invention. 

Figs. 4a - 4b is a flowchart detailing a process for a 
for retrieving and downloading component files by 
a virtual machine in accordance with an embodi- 
ment of the invention; 

Fig. 5 illustrates an embodiment of a Java virtual 
machine in accordance with an embodiment of the 
invention; and 

Fig. 6 illustrates a computer system that can be em- 
ployed to implement the present invention 

DETAILED DESCRIPTION OF THE EMBODIMENTS 

[0012] In the following description, frameworks and 
methods of providing on-demand file downloading and 
execution of files within, for example, a browser/server 
environment are described. Although, the invention will 
initially be described in terms of a Java based applica- 
tion and/or applet residing in a multithreaded, object ori- 
ented computing system, it should be noted that the 
present invention can be used in any system that is ca- 



pable of handling http requests and responses. 
[0013] In general, when a user desires to run an ap- 
plet embedded in a Java based browser, a Java virtual 
machine (JVM) that includes a class loader generates 
5 a file download request in the form of an http request to 
a particular server computer that contains the appropri- 
ate applet component files. Typically, the component 
files include a main class file used as an entry point for 
execution of the applet as well as other Java class files 
10 used in furtherance of the execution of the applet. In ad- 
dition, the component files may include image and 
sound files, referred to more generally as resource files 
that provide a user interface for the applet. In a preferred 
embodiment, related component files are grouped in 
15 what is referred to as a package. The package, in turn, 
is typically compressed and stored in corresponding 
JAR files within, or coupled to, the server computer. In 
some cases, multiple packages are stored within a sin- 
gle Java Archive (JAR) file and in other cases, single 
class files (with no accompanying package) are stored 
in an appropriately compressed state, if so desired, in a 
corresponding JAR file. In some cases, a package can 
be stored amongst more than one JAR file. 
[0014] In one embodiment of the invention, afirst JAR 
file, referred to as the root JAR file, is associated with 
an index file that contains information that relates to the 
mapping of various packages (or individual class files ) 
and their corresponding JAR files. In order to execute 
the applet, a class loader associated with the Java vir- 
tual machine queries the root JAR file and determines 
whether or not a corresponding index file is present. If 
an index file is present, the class loader creates a HASH 
table that is based upon the contents of the index file. 
In a preferred embodiment, the HASH table index pro- 
vides a mapping of all packages and all corresponding 
JAR files required to execute the applet by the JVM. Dur- 
ing runtime, when a particular file is required by the JVM, 
the class loader queries the HASH table in order to di- 
rectly access the appropriate JAR file to be downloaded. 
In this way, the need to perform a linear search of all 
JAR files and component files contained therein is sub- 
stantially avoided. 

[0015] By reducing, or eliminating the linear searching 
of all component files during runtime, the amount of time 
and network resources required to execute a given ap- 
plet is substantially reduced. In this way, it becomes eco- 
nomically feasible to execute and thereby apply more 
complex applets and/or applications than is currently 
possible. This increase in on-demand file downloading 
and the resultant improvement JVM runtime perform- 
ance provides greater flexibility in providing complex on- 
line services related to, for example, interactive stock 
trading, on-line bidding and many other e-commerce 
transactions that require intensive real time computing 
capabilities. 

[0016] The invention will now be described in terms 
of a Java Virtual Machine embedded within, or coupled 
to, a Java based browser resident in a client computer 
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hat is typically used to execute a applet. The applet in 
turn has a number of associated component files, such 
as class and image files, stored in, or coupled to, a serv- 
er (host that is connected to the client computer. In most 
cases, the server is coupled to other interconnected 
computers to form a distributed computer system such 
as represented by the Internet. It should be noted how- 
ever, that the invention can be implemented in any sys- 

Jol^r r° Vidin9 r6SOUrCe efficient °n-demand 
download and execution of files used to, for example 

run embedded, or other type, applications is important' 

[0017] Referring nowto Fig. 3, a Java based browser/ 

server system 300 in accordance with an embodiment 

of the mention is shown. The system 300 includes a 

client computer 302 coupled to a server (host) computer 

304^ y p,cally, the host computer 304 Is part ofadfetrib- 

uted interconnected computer network (not shown) 

such as the Internet, but can also be part of a local Z 

network, sometimes referred to as an intranet. In order 

to facilitate communication between the various users 

2 S° mmerS tha< f0rm ,he ne,w °* tne client com- 
puter 302 utnizes the graphical user interfaces present- 
ed b y a web page 306 resident in a Java based browser 
308 (sometimes referred to as an http page). Most 
browsers are formed of various HTTP statements In 
some cases, an applet 310 is formed by selectively em- 
bedding certain HTTP statements within the HTTP 
framework of the web page 306. By embedding various 
applets wrthin the browser, the browser user can inde- 
pendently run various applications from a single brows- 
er thereby facilitating various interactive events be- 

S.« ? US6r and ,he com P u,6r ne 'work. 

looiB] In the described embodiment, a Java Virtual 

Machme(JVM)3l2described in detail with reference to 
Fig. 5 executes the applet 310 in the described embod- 
iment by instantiating a class loader 31 4. The class load- 
er 314 has the responsibility to retrieve files as directed 
by the JVM 312 in the execution of the applet 310 !n 
order to execute the applet 310, however, various com- 

ov° jS Si', S, °, red in ^ 304 must 06 ide « 
by JVM 312, retneved by the class loader 314 and ulti- 
mately downloaded to the JVM 312 for execution. In the 
embodiment shown in Fig. 3, the component files cor- 
responding to the applet are stored in various JAR files 

IS 1 ? T d If* in 0rd9r 10 proper * execule 'he 
applet 310, Java class files as well as resource files 

such as .mage and/or sound files may be required In a 

preferred embodiment, the various related component 

files are grouped into what is referred to as packages 

the file 1 ,< / f " e 2 C,aSS ' 8nd * acbss ' such »■! 
J» file 1 .class (commonly referred to as a main class 

file) provides an entry point for the JVM 312 to start ex- 

ecutrng the applet 310. Typical*, the main class is the 

first application class loaded by the JVM 312 which 

^^**™™~^*™*« 

[001 9] Continuing the description of the system 300 
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li 9 l P f Cte9e P » 8t ° red in JAR file JAR 2. deludes 
vanous additional class files, file lO.class, fill 11 class 
and 12. class, used in one form or another in the exe- 
cutron of the applet 310. An important aspect to note is 
that in some cases, a single class file, such as f -class 
may not be associated with any particular package By 
way of example, the file f 00 .class is no. associated with 
any particular package but is also stored in JAR file 

[0020] It is also significant to note that in some cases 
a package can be stored in more than one JAR file such 
tha t a , particular package can be associated with a list 
of JAR files. Such a situation is shown in Fig 3 with re- 
's KESX 1 bein9S,oredin 

Sin T", JVM 312 be9ins 10 execut * the ap- 
plet 310 the class loader 314 associated with the JVM 

jIr m a 1£ 6 T JAR fll6 ' *"* in ,his sample, is 
JAR file JAR The class loader 314 will then determine 
» if an index file 316 that maps all packages to corre- 
spond^ JAR files is included in the root JAR file JAR, 
If there exists such an index file, the ctass loader 314 
uses .nformation contained in the indexfile 316tocreate 

*s hashI^o 318 - 3 Preferred embodiment, the 
HASH table 318 provides a mapping between all pack- 
ages associated with the applet 310 and the corre- 
spondrng JAR files in which those packages can be 
ound Once the HASH table 318 has been created, the 
class loader 314 then reads the HASH table 318 to as- 
nT, thS JAR file in m ,he ™" class file is located 

(JAR.]). 

[0022] Once the main class file has been located the 
class loader 314 directly downloads the appropriate 
JAR file as indicated by the HASH table 318 and ac- 

toTMut?^ main ClaSS file Wnjch is then loaded 
to the JVM 312. Once the JVM 312 has retrieved the 
down oaded main class file, the JVM 312 begins execu- 
tion of the applet 310. While the JVM 312 is executing 

40 I" ufi!! 31 °' ' he °' aSS load9r continues to que™ 
« the HASH table index 31 8 for the location of class 3 
or resource files as requested by the JVM 312 in order 
to continue executing the applet 310. In this way, the 
need to perform linear searching of the class and re- 
source files stored within the various JAR files stored in 
« the host computer 304 is substantially reduced or in 

somecases, eliminated. Eventually, execution of theap- 
plet 310 ceases. It should be noted that the JVM 312 
can execute multiple applets. 
[0023] Figs. 4a and 4b illustrate a flowchart detailing 
h P™ 8 !, 400 for downloading and executing files in a 
distributed network environment in accordance with one 
embodiment of the invention. The process 400 begins 
m F,g. 4a at 402 by the browser resident onaclient com 
bs ITJTT 9 ^ downloadi "9 an applet from a 
server (host) computer. A JVM resident on the client 
computer mterprets the main class tags and archive file 
tegs corresponding to the downloaded applet at 404 
The main class tags and archive file tags provide the 
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JVM with file identifiers subsequently used to identify 
the various applet component files stored in memory de- 
vices coupled to the host computer. At 406, using the 
main class tags, the JVM downloads and opens the root 
jar file which may contain the main class files associated 
with the applet. A determination is then made at 408 
whether or not an index file is associated with the root 
jar file. If it is determined that there is no associated in- 
dex file, then a default linear search of all JAR files is 
performed at 410. Otherwise, the class loader in the 
JVM constructs a HASH table based upon the index file 
that maps all packages and/or class files not in packag- 
es to their respective JAR files at 412. 
[0024] Turning to Fig. 4b, once the class loader has 
formed the HASH table, a determination is made at 414 
of the package name associated with a requested class 
file. If, at 416, it is determined that the package name 
associated with the requested file is not in the HASH 
table, then the requested file name itself is used to query 
the HASH table at 418. This particular situation arises 
when, for example, a single class file is not related to 
any other class files and is therefore not associated with 
a particular package. This case is illustrated in Fig. 3 by 
the f 00 -class file being stored in the JAR file JARg. 
[0025] If, however, the package name is found to be 
included in the HASH table at 416, then the package 
name is mapped to the associate JAR file(s) using the 
HASH table at 420. It should be noted that there can be 
any number of JAR files corresponding to a particular 
package name and that a particular JAR file can be as- 
sociated with more than one package name. These cas- 
es are aptly illustrated and duly noted in Fig. 3. Once 
the appropriate JAR file(s) have been identified, the lin- 
ear search algorithm is used to search the JAR files on 
the return list which are downloaded one by one and 
searched for the requested class file at 422. (It should 
be noted that in some cases the return list could be emp- 
ty indicating an error) In one embodiment, once the ap- 
propriate JAR files are identified on the return list, the 
first JAR file is downloaded and searched. 
[0026] If it is determined that the downloaded JAR file 
contains the requested file at 424, then the requested 
class file is retrieved and loaded into the JVM at 426. If, 
however, the requested file is not in the downloaded 
JAR file, then a determination is made at 428 whether 
or not there are additional JAR files on the return list. If 
there are no additional JAR files, then an error has oc- 
curred and an error flag is thrown at 430. On the other 
hand, if there are additional JAR files on the return list, 
then the next JAR file on the return list is downloaded 
at 432 and control is passed to 424 to determine whether 
or not the requested file is present in the next download- 
ed JAR file. 

[0027] Fig. 5 is a block diagram of a virtual machine 
500 that is suitable for implementing the present inven- 
tion. When a computer program, e.g., a computer pro- 
gram written in the Java programming language, is ex- 
ecuted, source code 502 is provided to a compiler 504 



within compiletime environment 506. Compiler 504 
translates source code 502 into bytecodes 508. In gen- 
eral, source code 502 is translated into bytecodes 508 
at the time source code 502 is created by a software 

5 developer. 

[0028] Bytecodes 508 may generally be reproduced, 
downloaded, or otherwise distributed through a network 
or stored on a storage device. In the described embod- 
iment, bytecodes 508 are platform independent. That is, 

10 bytecodes 508 may be executed on substantially any 
computer system that is running on a suitable virtual ma- 
chine. 

[0029] Bytecodes 508 are provided to a runtime envi- 
ronment 510, which includes virtual machine 312. Runt- 
1$ ime environment 510 may generally be executed using 
a processor or processors such as processor 602 de- 
scribed below with reference to Fig. 6. Virtual machine 
312 includes a compiler 512, an interpreter 514, and a 
runtime system 516. Bytecodes 508 may be provided 
either to compiler 51 2 or to interpreter 51 4. 
[0030] When bytecodes 508 are provided to compiler 
512, methods contained in bytecodes 508 are compiled 
into machine instructions. In one embodiment, compiler 
512 is a just-in-time compiler, which delays the compi- 
lation of methods contained in bytecodes 508 until the 
methods are about to be executed. When bytecodes 
508 are provided to interpreter 514, bytecodes 508 are 
read into interpreter 514 one bytecode at a time. Inter- 
preter 514 then performs the operation defined by each 
bytecode as each bytecode is read into interpreter 514. 
That is, interpreter 514 "interprets" bytecodes 508, as 
will be appreciated by those skilled in the art. 
[0031] When a method is invoked by another method, 
or is invoked from runtime environment 510, if the meth- 
od is interpreted, runtime system 516 may obtain the 
method from runtime environment 510 in the form of se- 
quences of bytecodes 508, which may be directly exe- 
cuted by interpreter 51 4. If, on the other hand, the meth- 
od that is invoked is a compiled method that has not 
been compiled, runtime system 516 also obtains the 
method from runtime environment 510 in the form of a 
sequence of bytecodes 508, which then may go to ac- 
tivate compiler 512. Compiler 512 then generates ma- 
chine instructions from bytecodes 508 and the resulting 
machine-language instructions may be executed direct- 
ly by operating system 518. The machine-language in- 
structions are discarded when virtual machine 31 2 ter- 
minates. The operation of virtual machines or, more par- 
ticularly, Java virtual machines, is described in more de- 
tail in The Java Virtual Machine Specification by Tim 
Lindholmand Frank Yellin (ISBN 0-201 -63452-X), which 
is incorporated herein by reference. 
[0032] Fig. 6 illustrates a computer system 600 that 
can be employed to implement the present invention. 
The computer system 600 or, more specifically, CPUs 
602, may be arranged to support a virtual machine, as 
will be appreciated by those skilled in the art. As is well 
known in the art, ROM acts to transfer data and instruc- 
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Hons uni-directionally to the CPUs 602, while RAM is 
used typically to transfer data and instructions in a 

222? T° er CPUS 602 may 9 eneral| V ""cWe 
2 fZ ZZ pr0cessors ' primary storage devic 
604 606 m ay include any suj , ab|e 9 . reada _ 

ble media. A secondary storage medium 608, which is 
vpically a mass memory device, is also coupled bi-di- 
ec^nally to CPUs 602 and provides additional data 
storage capacity. The mass memory device 608 is a 
computer-readable medium that may be used to store 

SEE" inC ' Udin9 C ° mpUter COde ' data ' and th * "ke. 
TyP^ally.massmemory device 608 is a storage medium 
such as a hard disk or a tape ^ J ™ 

ftan primary storage devices 604, 606. Mass memory 
storage device 608 may take the form of a magnetic or 
paper tape reader or some other wel.-known ££ I 
w.H be appreciated that the information retained within 
the mass memory device 608, may, in appropriate cas- 
es be incorporated in standard fashion as part of RAM 

eoeasv^ua.memory.Aspecificprimarystoragedevte 
604 such as a CD-ROM may also pass data uni-direc 
tionallytotheCPUs602 "ni-oirec 
[0033] CPUs 602 are also coupled to one or more in- 

P^putdeviceseto.hatmayinclude.bmarnX 
rted to dev^es such as video monitors, track balls, 
mce keyboards, microphones, touch-sensit^e dis- 
plays, transducer card readers, magnetic or paper tape 
readers, tablets, sty.uses. voice or handwrrt'ng' r £ 
n^ers, or other well-known input devices such as, of 
course, other computers. Finally, CPUs 602 optionally 
may be coupled to a computer or telecommunications 
network, e.g., an , nternet netWQrk Qr an • 

n r° fk COnnection as shown generally 
a 612. With such a network connection, it is contem- 

he network, or might output information to the network 
in the course o performing the above-described method 
steps Such information, which is often represented as 
a se quen c e of instructions to be executed using CPUs 

602 maybereceivedf ro mandoutputtedtothenetwork 
for example, ,n the form of a computer data signal em^ 
bodied .n a carrier wave. The above-described devices 
and materials will be familiar to those of skill in the com- 
puter hardware and software arts 
[0034] Although only a few embodiments of the 
present invention have been described, it should be un- 
derstood hat the present invention may be embod ed 

loZrm SP6CffiC '° rmS V " th0Ut de P arti "9 »™ the 
spMTt or the scope of the present invention 

[003q Although the methods of providing efficient file 
col ada : d f eCUtioninab ^^envirLent na 
co dance wrth the present invention are particularly sutt- 
able for implementation with respect to a Java™ based 
envrronment, the methods may generally be applied in 

metttod. are suitable for use in platform-independent 
object-based environments. It should be appreciated 
that the methods may also be implemented hSSE 
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tributed object-oriented systems 
[0036] While the present invention has been de- 
scribed as being used with a computer system that has 
an associated web browser and web server, it should 
beapprecatedthatthepresent invention may generally 
be imp emented on any suitable object-oriented compu 
ter system. Therefore, the present examples are to be 
considered as illustrative and not restrictive, and the in- 
vention ,s not to be limited to the details gK,en here n 
« but may be modified within the scope of the appended 
claims along wrth their full scope of equivalents 
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1 • A method for executing an applet, comprising: 

providing a file download request for a root file 
to a particular server computer by a virtual ma- 
chine included in a browser used to execute the 
applet, wherein the requested root file includes 
applet component files used by the virtual ma- 
chine to execute the applet wherein related 
ones of the component files are grouped into a 
corresponding package; 
determining if the root file includes an index file 
that contains information that relates the map- 
ping of the package to corresponding related 
applet component files 

when the root file includes the index file creat- 
ing a HASH table based upon the contents of 
the ,ndex file, the HASH table providing a map- 
ping of all packages and all correspond^ g com- 
ponent files that are used by the virtual machine 
to execute the applet; 

during virtual machine runtime, querying the 
HASH table for a location of a particular applet 
component file; and 

directly downloading the particular applet com- 
ponent file based upon the location provided by 
the HASH table to the virtual machine. 

2. A method as recited in claim 1 , wherein the request- 
ed file is a Java Archive (JAR) file. 

3. A method as recited in claim 1 , wherein the root file 
includes a main class file that identifies an entry 
point for the applet. y 
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so 4. 



A method as recited in claim 3, wherein the HASH 
table , s usedtoidentifythe location of the main class 



6. A method as recited in claim 1, wherein the virtual 
machine substantia^ simultaneously executes a 
plurality of applets. 



6. 



A method as recited in 3, wherein each of the plu- 
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rality of applets has an associated root file. 

7. A method as recited in claim 4, wherein each of the 
root files has an associated index file corresponding 

to the. associated applet. 5 

8. A method as recited in claim 5, wherein each of the 
root files includes a main class file used to identify 
an entry point for each of the corresponding applets. 

10 

9. A method as recited in claim 5, wherein each of the 
index files is used to create a corresponding HASH 
table that is used to identify the location of the main 
class file which in turn provides the corresponding 
entry point for each of the applets. 15 
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